

Mar-24-04 08:15A

9708986439

P.01



IN THE UNITED STATES PATENT AND TRADEMARK OFFICE

Appl. No. : 09/496,844  
 Applicant : Patrick KNEBEL, et al.  
 Filed : February 2, 2000  
 Title : METHOD AND COMPUTER SYSTEM FOR DECOMPOSING MACROINSTRUCTIONS INTO MICROINSTRUCTIONS AND FORCING THE PARALLEL ISSUE OF AT LEAST TWO MICROINSTRUCTIONS (Amended)  
 TC/A.U. : 2183  
 Examiner : Huisman, David J.  
 Docket No. : 10971393-1  
 Customer No. : 022879

Commissioner for Patents  
 P.O. Box 1450  
 Alexandria, Virginia 22313-1450

**RECEIVED**

MAR 26 2004

Technology Center 2100

**DECLARATION OF PATRICK KNEBEL PURSUANT TO 37 C.F.R. § 1.131**

Dear Sir:

1. Prior to May 18, 1999, the filing date of U.S. Patent No. 6,330,657 to Col et al., we reduced to practice the invention described in the claims of the present application.
2. At least by February 24, 1999, we reduced to practice a method and computer system that include decomposing macroinstructions into microinstructions, forcing the parallel issue of at least two microinstructions, and if an exception occurs in any of the microinstructions, canceling all of the microinstructions.
3. Attached as Exhibits 1 and 2 are two sets of RTL codes that evidence the reduction to practice of these features. The RTL code in Exhibit 1 is dated February 24, 1999. The RTL code in Exhibit 2 is dated December 4, 1998.
4. The RTL code in Exhibit 1 illustrates forcing the parallel issue of at least two microinstructions. The RTL code in Exhibit 2 illustrates if an exception occurs in any of the microinstructions, canceling all of the microinstructions.

*Patrick Knebel* 3/24/04

ar-24-04 08:16A

9708986439

P.02

5. The acts related above all took place in the United States of America.

6. The declarant further states that the above statements were made with the knowledge that willful false statements and the like are punishable by fine and/or imprisonment, or both, under Section 1001 of Title 18 of the United States Code, and that any such willful false statement may jeopardize the validity of this application or any patent resulting therefrom.

Date: March 24, 2004

  
\_\_\_\_\_  
Patrick Knebel

DATE  
MAR 24 2004

bnddeps.txt

!=====  
! \$Header: /h1/logic/rtl/dev/hdl/src/bnddeps.hdl 1.25 1999/02/24 03:51:54 h1cad  
! Exp \$  
=====

bnddeps.hdl

Author: Patrick Knebel  
Date: 10/22/97  
Copyright (c) 1997, 1998, 1999 Hewlett Packard Corporation

RECEIVED

MAR 26 2004

Technology Center 2100

Bifrost Bundle Builder; The BUNDler!

Takes the uops and immediates from UDQ, checks them for dependencies, and ships syllables off to IFR's Instruction Buffer.

-----  
| DE4 | SCH | XMT | ROT |  
-----



bnddeps.hdl

Control block for checking whether to issue 1 or 2 syllables to EM. Check register dependencies and other control bits to determine dual issue.

----- Modification History ----- Also see fhlist(1) for an SBCM log -----

990218 anuj- add clock gaters for powerup/down bifrost clocks  
981211 rcb - bug fix, cond7 needed to include any non-zero subop type  
981118 pjk - move register dependency checking from bnddeps to bndpaird  
980715 pjk - remove SMC  
980501 pjk - change fp-stkptr dependency rules  
971218 pjk - yet another (different) way to encode uop-subtype. Instead of using the 1-bit aflag field, create a new 3-bit subtype field  
971111 pjk - put in new uotype encodings  
use aflags (future subuotype) in place of ftosrd and store-op  
971022 pjk - new

FUB bnddeps;

BEGIN "bnddeps"

----- Included Files -----

sourcefile "p7includes.def"  
sourcefile "syn\_maclib.def"  
sourcefile "bif.def"  
sourcefile "p7params.def"  
sourcefile "uop.def"  
sourcefile "logical\_register.typ"  
sourcefile "idu.def"

----- Ports, signals, and clock -----

sourcefile "bnddeps.ifc"  
sourcefile "bnddeps.int"  
sourcefile "clock.typ"

----- Compile Time Variables -----

Page 1

bnddeps.txt

```
CtINTEGER j endc

----- MAIN -----

STRUCTURAL MAIN;
BEGIN "bnddeps MAIN"

! Generate internal clock
GaterCKL(clk, BndClkEn111B, BnddepsGCInt, qclkBnddeps);

!-----!
! Bundle logic decides whether to send 0, 1, or 2 uops to EM
!-----!

! Hardware issues 0 uops if:
! There are no uops to send
bndnop1 := vNOT(BndUopMuxUopValid_0SchB);

! or if older uop is "bundle always with successor" and there is no successor (yet)
bndnop2 := vAND3(vNOT(BndUopMuxBndHint_0SchB[1]),
                  BndUopMuxBndHint_0SchB[0],
                  vNOT(BndUopMuxUopValid_1SchB));

BndNoIssueSchB := vOR2(bndnop1, bndnop2);

! Note: BndNoIssueSchB has priority over BndDualIssueSchB

! Hardware can dual-issue 2 uops iff:

! Diagnose bit to turn off bundling
! (fixme: short-term just hack it)
bndcond0 := NOT EmtSnglIssEnB; ! enable bundling

! Older inst is not (sync or never pair with successor)
! Ynger inst is not (sync or always pair with successor)
bndcond1 := vNOR2(BndUopMuxBndHint_0SchB[1],
                  BndUopMuxBndHint_1SchB[0]);

! 2nd uop is not i0
! i0 must not bundle with predecessor
bndcond2 := vNAND3(BndUopMuxUopType_1SchB[2],
                  BndUopMuxUopType_1SchB[1],
                  vNOT(BndUopMuxUopType_1SchB[0]));

! 2 or more uops available from udq and the save latches
bndcond3 := BndUopMuxUopValid_1SchB;

! 1st and 2nd uops not both (load/store/bif) ops
! fixme: should we combine this rule and the fp-stk rule
! to disable all combinations of bif/f/m0/m2?
! fixme: should we allow 2 loads/cycle? TLL has some data
! debug event muxes that would have to change.
bndcond4 := vNAND4(vNOT(BndUopMuxUopType_0SchB[2]),
                  vOR2(BndUopMuxUopType_0SchB[1],
                        vNOT(BndUopMuxUopType_0SchB[0])),
                  vNOT(BndUopMuxUopType_1SchB[2]),
                  vOR2(BndUopMuxUopType_1SchB[1],
                        vNOT(BndUopMuxUopType_1SchB[0])));

! no fp-tos WAW or RAW hazard
! don't bundle if both uops are Bif/f/m0/m2 and subtype is fp
bndcond5 := vNAND4(vNOT(BndUopMuxUopType_0SchB[2]),
                  BndUopMuxSubType_0SchB[2],
```

```

bnddeps.txt
vNOT(BndUopMuxUopType_1SchB[2]),
BndUopMuxSubType_1SchB[2]);

! both uops are not flushing tbit.iA or cmp.iA
bndcond7 := vNAND4(BndUopMuxUopType_0SchB[2],
                    BndUopMuxSubType_0SchB <> '000,
                    BndUopMuxUopType_1SchB[2],
                    BndUopMuxSubType_1SchB <> '000);

! no eflags WAW hazard (RAW can't happen)
! This check is no longer needed. The eflags h/w in the prodf unit
! can handle WAW hazards. And RAW cannot happen because the only readers
! are tbitia and prodf which are both IO syllables (always older).
! bndcondx := 1;

! the following rule is now covered by fp-tos hazard check above
! both uops are not of F type
!(ucode can override this by issueing "always bundle" hint)
bndcondx := vNAND2(vAND3(vNOT(BndUopMuxUopType_0SchB[2]),
                           vNOT(BndUopMuxUopType_0SchB[1]),
                           BndUopMuxUopType_0SchB[0]),
                           vAND3(vNOT(BndUopMuxUopType_1SchB[2]),
                           vNOT(BndUopMuxUopType_1SchB[1]),
                           BndUopMuxUopType_1SchB[0]));

! no smc alignment problems
! smc := (m2-op) and (store) and (eof) and (next instruction crosses a line)
bndcond6 := vNAND4(vAND3(vNOT(BndUopMuxUopType_0SchB[2]),
                           BndUopMuxUopType_0SchB[1],
                           vNOT(BndUopMuxUopType_0SchB[0])),
                           BndUopMuxSubType_0SchB[0],
                           vNOR3(vCMP(BndUopMuxFlowMarker_0SchB, P7U_NO_MARKER),
                           vCMP(BndUopMuxFlowMarker_0SchB, P7U_END_FLOW),
                           vCMP(BndUopMuxFlowMarker_0SchB, P7U_OIW_NOW)),
                           BndUopMuxLineCross_1SchB);

! fixme: Move the following rule to ucode:
! Ucode must mark I1 and B syllables as never bundle with successor
! 1st uop is not i1
bndcondx := vNAND2(BndUopMuxUopType_0SchB[2],
                    BndUopMuxUopType_0SchB[0]);

! Allow ucode to override normal dependency checking
BndForceDualSchB := vAND2(vNOT(BndUopMuxBndHint_0SchB[1]),
                           BndUopMuxBndHint_0SchB[0]);
BndCtlDependschB := vOR2(vNAND4(bndcond0, bndcond1, bndcond2, bndcond3),
                           vNAND3(bndcond4, bndcond5, bndcond7));

END "bnddeps MAIN";
END "bnddeps";

```

fpucntrls.txt

```
!=====
!&      $Header: /tmp/rtl/fpucntrls.hdl,v 1.22 1998/12/04 00:11:53 gwelte Exp $
!=====
```

fpucntrls.hdl

Author: Rohit Bhatia  
Date: 09/29/97

Copyright (c) 1997 Hewlett-Packard  
HP Proprietary

RCS information:  
\$Author: gwelte \$  
\$Date: 1998/12/04 00:11:53 \$  
\$Revision: 1.22 \$  
\$State: Exp \$  
\$Locker: \$

-----  
fpucntrls Fub functions  
-----

!FUB <fubname> @<attributes>;  
FUB fpucntrls;

BEGIN "fpucntrls"

-----  
! Global Constant/Macro Defines  
!-----

SOURCEFILE "p7includes.def"  
SOURCEFILE "syn\_maclist.def"  
SOURCEFILE "dp\_maclist.def"  
SOURCEFILE "emparams.def"  
SOURCEFILE "p7params.def"  
SOURCEFILE "emdecode.def"  
SOURCEFILE "reset.def"  
SOURCEFILE "fpu.def"

!!!-----  
!!! Local Constant/Macro Defines  
!!!-----

SOURCEFILE "<fubname>.def" <optional>  
<OR>  
<local macros> <optional>

DEFINE Dsr1\_RdFp4H = [FpuDsr1RdFp4H]  
DEFINE Dsr1\_WrFp4H = [FpuDsr1WrFp4H]  
DEFINE Dsr2\_RdFp4H = [FpuDsr2RdFp4H]  
DEFINE Dsr2\_WrFp4H = [FpuDsr2WrFp4H]

CTINTEGER k,p,sfnum ENDC

!!!-----  
!!! Interface/Clock Declaration  
!!!-----

SOURCEFILE "fpucntrls.ifc"

!!!-----

fpucntrls.txt  
Local Node/Variable Declarations

SOURCEFILE "fpucntrls.int"

===== Instrumentation and Debug Variables =====

SOURCEFILE "<fubname>.inst" <optional>  
<OR>  
<local instrumentation variable declaration,  
 WHENSTABLE PROC,  
 Instrumentation procedures> <optional>

===== Clock Description =====

SOURCEFILE "clock.typ"

===== MAIN Procedure =====

!IFC P7\_IS\_FV THENC SOURCEFILE "<fubname>.dir" ENDC

STRUCTURAL MAIN;

BEGIN "fpucntrls MAIN"

===== PSR info =====

VDFF(CLKGPU4,DcsPsrDFH111H,FpuPsrDFHFp1H);  
VDFF(CLKGPU4,DcsPsrDFL111H,FpuPsrDFLFp1H);

===== SIR Stall Generation =====

FORC k := 0 UPTO 1 DOC

VEDFF(CLKGPU4, FpuDsr1WrFp1H, f%k%\_UnsafeFp1H, f%k%\_UnsafeRecFp2H);  
f%k%\_UnsafeMxFp1H :=  
    VMUXE2(f%k%\_UnsafeFp1H, f%k%\_UnsafeRecFp2H,  
          FpuDsr1RdFp1H);

ENDC

FpuDisFmaSIRFp1H :=  
    VOR2(FpuF0FmaTypeFp1H AND fp\_DisableSIR111H AND FpuF0v1d0pFp1H,  
          FpuF1FmaTypeFp1H AND fp\_DisableSIR111H AND FpuF1v1d0pFp1H);

FpuEarlyGenSirFp1H :=  
    VOR3(FpuF0EarlyFltFp1H,FpuF1EarlyFltFp1H,  
          FpuDisFmaSIRFp1H);

FpuGenSirStallFp1H :=  
    VOR3((f0\_UnsafeMxFp1H) AND FpuF0Unsafev1dFp1H,  
          (f1\_UnsafeMxFp1H) AND FpuF1Unsafev1dFp1H,  
          FpuEarlyGenSirFp1H);

fpucntrls.txt

```

vRESdff(CLKfpu4,
    XpnBruFlushWrbH OR
    (SpuStallExeH AND NOT DccStallDetH) OR
    fp_SirStallFp2H,
    NOT DccStallDetH,
    FpuGenSirStallFp1H, FpuGenSirStallFp2H); ! reset ! enable ! d, q

vRSDdff(CLKfpu4,
    XpnBruFlushWrbH,
    FpuGenSirStallFp2H, FpuGenSirStallFp3H); ! reset ! d, q
vDff(CLKfpu4, FpuGenSirStallFp3H, FpuGenSirStallFp4H);

FpuSirStallFp2H :=
    vOr3(FpuGenSirStallFp2H,
        FpuGenSirStallFp3H,
        FpuGenSirStallFp4H);

! Local copy of FPU internal consumers
fp_SirStallFp2H := dpBUFFER(FpuSirStallFp2H);

=====

!!! REN
=====

FORC k := 0 UPTO 1 DOC
    ASSIGNC p := k + 4 ENDC

! Port Valid
vRESdff(CLKfpu4, FpuFlushRenH, FpuEnableRenH,
    IsdPort%p%VldRenH, FpuF%k%SylVldRegH);
vRESdff(CLKfpu4, FpuFlushRenH, FpuEnableRenH,
    FpuF%k%HasPred1RenH, FpuF%k%HasPred1RegH);
vRESdff(CLKfpu4, FpuFlushRenH, FpuEnableRenH,
    FpuF%k%HasPred2RenH, FpuF%k%HasPred2RegH);
ENDC

! Simd op can only be on one port
Fv_MUTEX(RendF0SimdOpRenH, RendF1SimdOpRenH,
    ("FP-SIMD op on both F0 and F1"));

! Replicate syllables on both ports for a SIMD op
FpuPort4IveBitRenB :=
    vMUXE2(IsdPort4IveBitRenB, IsdPort5IveBitRenB,
        RendF1SimdOpRenH);
FpuPort4SyllRenH[40:6] :=
    vMUXE2(RenPort4SyllRenH[40:6], RenPort5SyllRenH[40:6],
        RendF1SimdOpRenH);

FpuPort5IveBitRenB :=
    vMUXE2(IsdPort5IveBitRenB, IsdPort4IveBitRenB,
        RendF0SimdOpRenH);
FpuPort5SyllRenH[40:6] :=
    vMUXE2(RenPort5SyllRenH[40:6], RenPort4SyllRenH[40:6],
        RendF0SimdOpRenH);

! Replicate src ids on both ports for a SIMD op
FORC k := 0 UPTO 2 DOC
    FpuPort4pSrc%k%RenH :=
        vMUXE2(RenPort4pSrc%k%RenH, RenPort5pSrc%k%RenH,
            RendF1SimdOpRenH);
    FpuPort5pSrc%k%RenH :=
        vMUXE2(RenPort5pSrc%k%RenH, RenPort4pSrc%k%RenH,
            RendF0SimdOpRenH);
ENDC

```

## fpucntrls.txt

```

VRESdff(CLKfpu4, FpuFlushRenH, FpuEnableRenH,
         RendF0SimdOpRenH OR RendF1SimdOpRenH, f0_SimdOpRegH);
VRESdff(CLKfpu4, FpuFlushRenH, FpuEnableRenH,
         RendF0SimdOpRenH OR RendF1SimdOpRenH, f1_SimdOpRegH);
=====
!!! REG
=====

! Check for WAW
FpuDestSameRegH      :=
    vCMP(FpuF0DestIdRegH, FpuF1DestIdRegH) AND
    FpuF0GoodDestRegH AND FpuF1GoodDestRegH;

FORC k := 0 UPTO 1 DOC

!! Mac start signals
f%k%_MacStartRegL   :=
    vOR2(FpuF%k%SylVldRegH, f%k%_SimdOpRegH);

f%k%_SimdMacStartRegL := FpuF%k%SylVldRegH;

FpuF%k%GoodDestRegH :=
    vAND3(FpuF%k%SylVldRegH, FpuF%k%HasDestRegH,
          vBOR(FpuF%k%DestIdRegH[6:1]));

!! Illegal Op Flt
FpuF%k%IllegalOpRegH :=
    vOR3(FpuF%k%RsvdInstRegH,
          FpuF%k%IllgPredRegH,
          FpuF%k%HasDestRegH AND (vBNOR(FpuF%k%DestIdRegH[6:1])));

VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%IllegalOpRegH, FpuF%k%IllegalOpFp1H);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%IllgPredUncRegH, FpuF%k%IllgPredUncFp1H);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%BreakInstRegH, FpuF%k%BreakInstFp1H);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%NopRegH, FpuF%k%NopFp1H);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%AccFRFHRegH, FpuF%k%AccFRFHRegH);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%AccFRFLRegH, FpuF%k%AccFRFLRegH);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%ModHiRegH, FpuF%k%ModHiRegH);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%ModLoRegH, FpuF%k%ModLoRegH);
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%DivTypeRegH, FpuF%k%DivTypeFp1H);      ! F6+F7
VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%CmpTypeRegH, FpuF%k%CmpTypeFp1H);      ! F4+F5
VEDdff(CLKfpu4, FpuEnableRegH, f%k%_CmpC1sTypeRegH[9], FpuF%k%CmpC1sUncFp1H); ! Unc type

VEDdff(CLKfpu4, FpuEnableRegH, FpuF%k%DestIdRegH, FpuF%k%DestIdFp1H);

! Port,Dst Valid, Predicate Vld
VRESdff(CLKfpu4, FpuFlushRegH, FpuEnableRegH,
         FpuF%k%SylVldRegH, FpuF%k%SylVldFp1H);
VRESdff(CLKfpu4, FpuFlushRegH, FpuEnableRegH,
         FpuF%k%FlgTypeRegH, FpuF%k%UnsafeVldFp1H);
VRESdff(CLKfpu4, FpuFlushRegH, FpuEnableRegH,
         FpuF%k%GoodDestRegH, FpuF%k%GoodDestFp1H);
VRESdff(CLKfpu4, FpuFlushRegH, FpuEnableRegH,
         FpuF%k%HasPred1RegH, FpuF%k%HasPred1Fp1H);
VRESdff(CLKfpu4, FpuFlushRegH, FpuEnableRegH,
         FpuF%k%HasPred2RegH, FpuF%k%HasPred2Fp1H);
ENDC

VRESdff(CLKfpu4, FpuFlushRegH, FpuEnableRegH, f0_SimdOpRegH, FpuSimdResFp1H);
VEDdff(CLKfpu4, FpuEnableRegH, FpuDestSameRegH, FpuDestSameFp1H);

=====

```

fpucntrls.txt

!!! FP1

!!!=====

FORC k := 0 UPTO 1 DOC  
 ASSIGNC p := k + 4 ENDC

!-----

! Port valid qualified with Qp -> VldOp  
 FpuF%k%VldOpFp1H := FpuF%k%Sy1VldFp1H AND SpuQp%p%ExeH;

IFC (k = 0) THENC  
 f%k%\_VldFinstFp1H :=  
 vAND3(FpuF%k%GoodDestFp1H AND FpuF%k%Sy1VldFp1H,  
     FpuDestSameFp1H NAND SpuQp5ExeH,  
     SpuQp%p%ExeH);  
 FpuF%k%FRFUpdFp1H :=  
 vAND3(FpuF%k%GoodDestFp1H AND FpuF%k%Sy1VldFp1H,  
     FpuDestSameFp1H NAND SpuQp5ExeH,  
     SpuQp%p%ExeH);  
 FpuF%k%VldBypFp1H :=  
 vAND3(FpuF%k%GoodDestFp1H AND FpuF%k%Sy1VldFp1H,  
     FpuDestSameFp1H NAND SpuQp5ExeH,  
     SpuQp%p%ExeH);  
 ENDC  
 IFC (k = 1) THENC  
 f%k%\_VldFinstFp1H :=  
 vAND3(FpuF%k%GoodDestFp1H AND FpuF%k%Sy1VldFp1H,  
     FpuDestSameFp1H NAND SpuQp4ExeH,  
     SpuQp%p%ExeH);  
 FpuF%k%FRFUpdFp1H :=  
 vAND3(FpuF%k%GoodDestFp1H AND FpuF%k%Sy1VldFp1H,  
     FpuDestSameFp1H NAND SpuQp4ExeH,  
     SpuQp%p%ExeH);  
 FpuF%k%VldBypFp1H :=  
 vAND3(FpuF%k%GoodDestFp1H AND FpuF%k%Sy1VldFp1H,  
     FpuDestSameFp1H NAND SpuQp4ExeH,  
     SpuQp%p%ExeH);  
 ENDC

!-----

!-----  
 ! Generate the early faults  
 FpuF%k%IllegalOpFltFp1H := ! Illegal Op Flt  
 vOR2(FpuF%k%IllegalOpFp1H AND FpuF%k%VldOpFp1H,  
     FpuF%k%IllegalPredUncFp1H AND FpuF%k%Sy1VldFp1H);

FpuF%k%BreakFltFp1H := ! Break Flt  
 vAND2(FpuF%k%BreakInstFp1H, FpuF%k%VldOpFp1H);

FpuF%k%DisFRFHifltFp1H := ! Disabled FP Reg Hi Flt  
 vAND3(FpuF%k%AccFRFHifltFp1H, FpuPsrDFHFp1H, FpuF%k%VldOpFp1H);  
 FpuF%k%DisFRFLofltFp1H := ! Disabled FP Reg Lo Flt  
 vAND3(FpuF%k%AccFRFLofltFp1H, FpuPsrDFLFp1H, FpuF%k%VldOpFp1H);

FpuF%k%ResFldFltFp1H :=  
 vAND2(FpuF%k%RsvdFldFp1H, FpuF%k%VldOpFp1H);

FpuF%k%EarlyFltFp1H :=  
 vOR6(FpuF%k%IllegalOpFltFp1H,  
     FpuF%k%BreakFltFp1H,  
     FpuF%k%DisFRFHifltFp1H,  
     FpuF%k%DisFRFLofltFp1H,

```

fpuctrls.txt
FpuF%k%ResF1dF1tFp1H,
FpuF%k%SpecOpF1tFp1H);
!-----
!-----
! Check if unsafe is signalled for PMU FalseSIR event
FpuF%k%IsUnsafeExeH := ! Unsafe_signalled & Vld_Arith_Inst
VAND3(FpuF%k%UnsafeMxFp1H, FpuF%k%UnsafeVldFp1H, Pmc8f%k%TagExeH);
!-----
!-----
! Generate dest modify signals for PSR{mfh,mf1}
FpuF%k%ModHiExeH :=
VAND2(FpuF%k%ModHiFp1H, f%k%_VldFinstFp1H);
FpuF%k%ModLoExeH :=
VAND2(FpuF%k%ModLoFp1H, f%k%_VldFinstFp1H);
!-----
!-----
! Pred valids
FpuF%k%Pred0VldFp1H :=
VOR3(VAND4(FpuF%k%HasPred1Fp1H,
FpuF%k%CmpTypeFp1H, NOT FpuF%k%CmpC1sUncFp1H, SpuQp%p%ExeH),
VAND3(FpuF%k%HasPred1Fp1H,
FpuF%k%CmpTypeFp1H, FpuF%k%CmpC1sUncFp1H),
VAND2(FpuF%k%HasPred1Fp1H, FpuF%k%DivTypeFp1H));
FpuF%k%Pred1VldFp1H :=
VOR3(VAND4(FpuF%k%HasPred2Fp1H,
FpuF%k%CmpTypeFp1H, NOT FpuF%k%CmpC1sUncFp1H, SpuQp%p%ExeH),
VAND3(FpuF%k%HasPred2Fp1H,
FpuF%k%CmpTypeFp1H, FpuF%k%CmpC1sUncFp1H),
VAND2(FpuF%k%HasPred2Fp1H, FpuF%k%DivTypeFp1H));
!-----
! Valid bits
VRESdff(CLKFP4, FpuFlushFp1H, FpuAdvFp1H, FpuF%k%SylVldFp1H, FpuF%k%SylVldFp2H);
VRESdff(CLKFP4, FpuFlushFp1H, FpuAdvFp1H, FpuF%k%VldOpFp1H, FpuF%k%VldOpFp2H);
!VRESdff(CLKFP4, FpuFlushFp1H, FpuAdvFp1H, f%k%_VldFinstFp1H, f%k%_VldFinstFp2H);

VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%UnsafeVldFp1H, FpuF%k%UnsafeVldFp2H);
VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%IsUnsafeExeH, FpuF%k%IsUnsafeDeth);

VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%VldBypFp1H, FpuF%k%VldBypFp2H);
VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%Pred0VldFp1H, FpuPred0Vld%p%Fp2H);
VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%Pred1VldFp1H, FpuPred1Vld%p%Fp2H);
VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%FRFUpdFp1H, FpuF%k%FRFUpdFp2H);

VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%ModHiExeH, FpuF%k%ModHiDeth);
VRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
FpuF%k%ModLoExeH, FpuF%k%ModLoDeth);

VEDFF(CLKFP4, FpuEnableExeH,
FpuF%k%FlopCntExeH AND Pmc8f%k%TagExeH::3, FpuF%k%FlopCntDeth);

! Propagate the early faults
VEDFF(CLKFP4, FpuEnableExeH, FpuF%k%Illg1OpF1tFp1H, FpuF%k%Illg1OpF1tFp2H);

```

```

fpucntrls.txt

VEDFF(CLKGPU4, FpuEnableExeH, FpuF%k%BreakFltFp1H, FpuF%k%BreakFltFp2H);
VEDFF(CLKGPU4, FpuEnableExeH, FpuF%k%DisFRFH1FltFp1H, FpuF%k%DisFRFH1FltFp2H);
VEDFF(CLKGPU4, FpuEnableExeH, FpuF%k%DisFRFLoFltFp1H, FpuF%k%DisFRFLoFltFp2H);
VEDFF(CLKGPU4, FpuEnableExeH, FpuF%k%ResFltFp1H, FpuF%k%ResFltFp2H);
VEDFF(CLKGPU4, FpuEnableExeH, FpuF%k%SpecOpFltFp1H, FpuF%k%SpecOpFltFp2H);
VRESdff(CLKGPU4, FpuFlushExeH, FpuEnableExeH,
          FpuF%k%EarlyFltFp1H, FpuF%k%EarlyFltFp2H);
ENDC

! SimdResult signal piped down for bpx
VDFF(CLKGPU4, FpuSimdResFp1H, FpuSimdResFp2H);

=====
!!! FP2
====

FORC k := 0 UPTO 1 DOC
  ASSIGNC p := k + 4 ENDC

VDFF(CLKGPU4, FpuF%k%FlopCntDetH, FpuF%k%FlopCntWrbH);
VRSdff(CLKGPU4, FpuFlushFp2H, FpuF%k%EarlyFltFp2H, FpuF%k%EarlyFltFp3H);
VRSdff(CLKGPU4, FpuFlushDetH, FpuF%k%IsUnsafeDetH, FpuF%k%IsUnsafeWrbH);
! Valid bits
VRSdff(CLKGPU4, FpuFlushFp2H, FpuF%k%Sy1V1dFp2H, FpuF%k%Sy1V1dFp3H);
VRSdff(CLKGPU4, FpuFlushFp2H, FpuF%k%V1dOpFp2H, FpuF%k%V1dOpFp3H);
!VRSdff(CLKGPU4, FpuFlushFp2H, f%k%_V1dFinstFp2H, f%k%_V1dFinstFp3H);
VRSdff(CLKGPU4, FpuFlushDetH, FpuF%k%V1dBypFp2H, FpuF%k%V1dBypFp3H);
VRSdff(CLKGPU4, FpuFlushDetH, FpuF%k%FRFUpdFp2H, FpuF%k%FRFUpdFp3H);
ENDC

! SimdResult signal piped down for bpx
VDFF(CLKGPU4, FpuSimdResFp2H, FpuSimdResFp3H);

=====
!!! FP3
====

FORC k := 0 UPTO 1 DOC
  ASSIGNC p := k + 4 ENDC

! Qualify valids with XpnCommits
FpuF%k%Sy1V1dCmtFp3H      := FpuF%k%Sy1V1dFp3H AND XpnCommit%p%wrbB;
FpuF%k%V1dOpCmtFp3H      := FpuF%k%V1dOpFp3H AND XpnCommit%p%wrbB;
FpuF%k%V1dBypCmtFp3H      := FpuF%k%V1dBypFp3H AND XpnCommit%p%wrbB;

VDFF(CLKGPU4, FpuF%k%FlopCntWrbH AND FpuF%k%V1dOpCmtFp3H::3, FpuF%k%FlopCntFp4H);
VDFF(CLKGPU4, FpuF%k%IsUnsafeWrbH, FpuF%k%IsUnsafeFd4H);
! Valid bits
VDFF(CLKGPU4, FpuF%k%Sy1V1dCmtFp3H, FpuF%k%Sy1V1dCmtFp4H);
VDFF(CLKGPU4, FpuF%k%V1dOpCmtFp3H, FpuF%k%V1dOpCmtFp4H);
!VDFF(CLKGPU4, f%k%_V1dFinstFp3H AND XpnCommit%p%wrbB, f%k%_V1dFinstFp4H);
VDFF(CLKGPU4, FpuF%k%FRFUpdFp3H AND XpnCommit%p%wrbB, FpuF%k%FRFUpdFp4H);
VDFF(CLKGPU4, FpuF%k%EarlyFltFp3H AND XpnCommit%p%wrbB, FpuF%k%EarlyFltIntFp4H);
VDFF(CLKGPU4, f%k%_SimdOpFp3H, f%k%_SimdOpFp4H);
ENDC

=====
!!! FP4
====

FV_FORBIDDEN(FpuF0FlopCntFp4H[2] AND FpuF1FlopCntFp4H[2],
              ("Both F0 and F1 have a 4-flop instruction"));

```

fpucntrls.txt

```

FpuFlopCntFp4H[2:0]      :=      dpADD(FpuF0FlopCntFp4H[2:0], FpuF1FlopCntFp4H[2:0]);

FORC k := 0 UPTO 1 DOC
! mac1 operates on simdlo
f%k%_SimdMacINVTrapFp4H := VAND2(f%k%_SimdOpFp4H, f1_MacINVTrapFp4H);
f%k%_SimdOVFTrapFp4H   := VAND2(f%k%_SimdOpFp4H, f1_OVFTrapFp4H);
f%k%_SimdUDFTrapFp4H   := VAND2(f%k%_SimdOpFp4H, f1_UDFTrapFp4H);
f%k%_SimdINXTrapFp4H   := VAND2(f%k%_SimdOpFp4H, f1_INXTrapFp4H);
f%k%_SimdFPAFp4H       := VAND2(f%k%_SimdOpFp4H, f1_FPAFp4H);

f%k%_TrapStatFp4H[7:0]   :=
  f%k%_FPAFp4H &
  f%k%_SWAFp4H &
  (f%k%_INVTrapFp4H OR f%k%_MacINVTrapFp4H) &
  f%k%_DENTrapFp4H &
  f%k%_DIVTrapFp4H &
  f%k%_OVFTrapFp4H &
  f%k%_UDFTrapFp4H &
  f%k%_INXTrapFp4H ;
f%k%_SimdTrapStatFp4H[7:0]   :=
  f%k%_SimdFPAFp4H &
  f%k%_SimdSWAFp4H &
  (f%k%_SimdINVTrapFp4H OR f%k%_SimdMacINVTrapFp4H) &
  f%k%_SimdDENTrapFp4H &
  f%k%_SimdDIVTrapFp4H &
  f%k%_SimdOVFTrapFp4H &
  f%k%_SimdUDFTrapFp4H &
  f%k%_SimdINXTrapFp4H ;

! !-----
! Normal FP Trap DSR
FP_2STG_DSR(CLKGPU4, f%k%_TrapStatFp4H, f%k%_TrapStatFd4H,
  f%k%Dsr1_TrapStatFd4H,
  f%k%Dsr2_TrapStatFp4H, f%k%Dsr2_TrapStatFd4H,
  f%k%DsrA_TrapStatFd4H);

! SIMD FP Trap DSR
FP_2STG_DSR(CLKGPU4, f%k%_SimdTrapStatFp4H, f%k%_SimdTrapStatFd4H,
  f%k%Dsr1_SimdTrapStatFd4H,
  f%k%Dsr2_SimdTrapStatFp4H, f%k%Dsr2_SimdTrapStatFd4H,
  f%k%DsrA_SimdTrapStatFd4H);

! EBC DSR
FP_2STG_DSR(CLKGPU4, f%k%_EBCFp4H, f%k%_EBCFd4H,
  f%k%Dsr1_EBCFd4H,
  f%k%Dsr2_EBCFp4H, f%k%Dsr2_EBCFd4H,
  f%k%DsrA_EBCFd4H);
! !-----
```

FpuF%k%FaultFd4H :=  
 VBOR(f%k%\_TrapStatFd4H[6:3]),  
 VBOR(f%k%\_SimdTrapStatFd4H[6:3]));

FpuF%k%TrapFd4H :=  
 VBOR(f%k%\_TrapStatFd4H[2:0]),  
 VBOR(f%k%\_SimdTrapStatFd4H[2:0]));

! Drive FP Exceptions info to XPN

FpuF%k%ExcpFltFp4H := VAND3(FpuExcpUpdFp4H, FpuF%k%FaultFd4H, FpuF%k%UnsafevlIdFp2H);

FpuF%k%ExcpTrpFp4H :=

fpucntrls.txt

```

vAND3(FpuExcpUpdFp4H, FpuF%k%TrapFd4H, FpuF%k%UnsafeVldFp2H);

VEDFF(CLKGPU4, FpuExcpAdvExeH, FpuF%k%ExcpFltFp4H, FpuF%k%ExcpFltDeth); ! FP fault
VEDFF(CLKGPU4, FpuExcpAdvExeH, FpuF%k%ExcpTrpFp4H, FpuF%k%ExcpTrpDeth); ! FP trap

VEDFF(CLKGPU4, FpuExcpAdvExeH, f%k%_TrapStatFd4H, f%k%_TrapStatDeth);
VEDFF(CLKGPU4, FpuExcpAdvExeH, f%k%_SimdTrapStatFd4H, f%k%_SimdTrapStatDeth);
VEDFF(CLKGPU4, FpuExcpAdvExeH, f%k%_EBCFd4H, f%k%_EBCDeth); ! EBC
!

FpuF%k%IsrCodeDeth[0] :=  

  vMUXE4(f%k%_SimdTrapStatDeth[2],  

          f%k%_TrapStatDeth[5],  

          f%k%_TrapStatDeth[5] OR f%k%_SimdTrapStatDeth[5],  

          f%k%_TrapStatDeth[5] OR f%k%_SimdTrapStatDeth[5],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth); ! EM FpTrap  

          ! EM FpFault  

          ! Bif FpTrap  

          ! Bif FpFault

FpuF%k%IsrCodeDeth[1] :=  

  vMUXE4(f%k%_SimdTrapStatDeth[1],  

          f%k%_TrapStatDeth[4],  

          f%k%_TrapStatDeth[4] OR f%k%_SimdTrapStatDeth[4],  

          f%k%_TrapStatDeth[4] OR f%k%_SimdTrapStatDeth[4],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[2] :=  

  vMUXE4(f%k%_SimdTrapStatDeth[0],  

          f%k%_TrapStatDeth[3],  

          f%k%_TrapStatDeth[3] OR f%k%_SimdTrapStatDeth[3],  

          f%k%_TrapStatDeth[3] OR f%k%_SimdTrapStatDeth[3],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[3] :=  

  vMUXE4(f%k%_SimdTrapStatDeth[7],  

          f%k%_TrapStatDeth[6],  

          f%k%_TrapStatDeth[2] OR f%k%_SimdTrapStatDeth[2],  

          f%k%_TrapStatDeth[2] OR f%k%_SimdTrapStatDeth[2],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[4] :=  

  vMUXE4(f%k%_TrapStatDeth[2],  

          f%k%_SimdTrapStatDeth[5],  

          f%k%_TrapStatDeth[1] OR f%k%_SimdTrapStatDeth[1],  

          f%k%_TrapStatDeth[1] OR f%k%_SimdTrapStatDeth[1],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[5] :=  

  vMUXE4(f%k%_TrapStatDeth[1],  

          f%k%_SimdTrapStatDeth[4],  

          f%k%_TrapStatDeth[0] OR f%k%_SimdTrapStatDeth[0],  

          f%k%_TrapStatDeth[0] OR f%k%_SimdTrapStatDeth[0],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[6] :=  

  vMUXE4(f%k%_TrapStatDeth[0],  

          f%k%_SimdTrapStatDeth[3],  

          'b0 OR 'b0,  

          'b0 OR 'b0,  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[7] :=  

  vMUXE4(f%k%_TrapStatDeth[7],  

          f%k%_SimdTrapStatDeth[6],  

          f%k%_TrapStatDeth[6] OR f%k%_SimdTrapStatDeth[6],  

          f%k%_TrapStatDeth[6] OR f%k%_SimdTrapStatDeth[6],  

          FpuIveMode111H & FpuF%k%ExcpFltDeth);

FpuF%k%IsrCodeDeth[8] :=  

  vMUXE4(f%k%_EBCDeth,  

          'b0,  

          FpuBifMMX20pFp2H,  

          FpuBifMMX20pFp2H,

```

```

        fpucntrls.txt
        FpuIveMode111H & FpuF%k%ExcpFltDetH);

ENDC

FpuIsrCodeDetH[8:0]      :=
  vMUXE4(FpuF1IsrCodeDetH[8:0],
          FpuF0IsrCodeDetH[8:0],
          FpuF0IsrCodeDetH[8:0] OR FpuF1IsrCodeDetH[8:0],
          FpuF0IsrCodeDetH[8:0] OR FpuF1IsrCodeDetH[8:0],
          FpuIfMMX2OpFp2H & (FpuF0ExcpFltDetH OR FpuF0ExcpTrpDetH));

FORC k := 0 UPTO 1 DOC
! Valid bits
vDFF(CLKGPU4, FpuF%k%Sy1v1dCmtFp4H, FpuF%k%Sy1v1dCmtFwbH);
vDFF(CLKGPU4, FpuF%k%V1dOpCmtFp4H, FpuF%k%V1dOpCmtFwbH);
vDFF(CLKGPU4, 'b0, F%k_V1dFinstWrbH);
vDFF(CLKGPU4, FpuF%k%FRFUpdFp4H, FpuF%k%FRFUpdFwbH);
ENDC

! Drive Early Fault indications to XPN
FpuF0EarlyFltFp4H      :=
  vAND2(FpuExcpUpdFp4H, FpuF0EarlyFltFp2H) ;
FpuF1EarlyFltFp4H      :=
  vAND2(FpuExcpUpdFp4H, FpuF1EarlyFltFp2H) ;
FpuI11g1OpFltFp4H      :=
  vOR2(vAND2(FpuF0I11g1OpFltFp2H, FpuF0EarlyFltFp4H),
        vAND3(FpuF1I11g1OpFltFp2H, FpuF1EarlyFltFp4H,
               NOT FpuF0EarlyFltFp4H));
FpuBreakFltFp4H        :=
  vOR2(vAND2(FpuF0BreakFltFp2H, FpuF0EarlyFltFp4H),
        vAND3(FpuF1BreakFltFp2H, FpuF1EarlyFltFp4H,
               NOT FpuF0EarlyFltFp4H));
FpuDisSFRHiFltFp4H     :=
  vOR2(vAND2(FpuF0DisSFRHiFltFp2H, FpuF0EarlyFltFp4H),
        vAND3(FpuF1DisSFRHiFltFp2H, FpuF1EarlyFltFp4H,
               NOT FpuF0EarlyFltFp4H));
FpuDisSFRFLoFltFp4H    :=
  vOR2(vAND2(FpuF0DisSFRFLoFltFp2H, FpuF0EarlyFltFp4H),
        vAND3(FpuF1DisSFRFLoFltFp2H, FpuF1EarlyFltFp4H,
               NOT FpuF0EarlyFltFp4H));
FpuResF1dFltFp4H       :=
  vOR2(vAND2(FpuF0ResF1dFltFp2H, FpuF0EarlyFltFp4H),
        vAND3(FpuF1ResF1dFltFp2H, FpuF1EarlyFltFp4H,
               NOT FpuF0EarlyFltFp4H));
FpuSpecOpFltFp4H        :=
  vOR2(vAND2(FpuF0SpecOpFltFp2H, FpuF0EarlyFltFp4H),
        vAND3(FpuF1SpecOpFltFp2H, FpuF1EarlyFltFp4H,
               NOT FpuF0EarlyFltFp4H));

=====FWB=====
vDFF(CLKGPU4, FpuIsrCodeDetH, FpuIsrCodeWrbH);
FpuIsrCodeFwbH[8:0]      := dpBUFFER(FpuIsrCodeWrbH[8:0]);

=====Deferred Stall Register(DSR) Logic=====
=====

!-----
! Generate the update and drive DSR signals

```

fpucntrls.txt

```

vDFF(CLKGPU4, SpuStallExeH, FpuExeStallDetH);

FpuDetStallDetH      := vOR2(DccStallDetH, fp_SirStallFp2H);
vDFF(CLKGPU4, FpuDetStallDetH, FpuDetStallWrbH);
vDFF(CLKGPU4, fp_SirStallFp2H, fp_SirStallWrbH);

FpuDsr2WrFp2H      :=  
    VAND2(FpuDetStallDetH, NOT FpuDetStallWrbH);           ! Load the DetDSR
vDFF(CLKGPU4, FpuDsr2WrFp2H, FpuDsr2WrFp3H);
vDFF(CLKGPU4, FpuDsr2WrFp3H, FpuDsr2WrFp4H);

FpuDsr2RdFp2H      :=  
    VAND2(NOT FpuDetStallDetH, FpuDetStallWrbH);           ! Read the DetDSR
vDFF(CLKGPU4, FpuDsr2RdFp2H, FpuDsr2RdFp3H);
vDFF(CLKGPU4, FpuDsr2RdFp3H, FpuDsr2RdFp4H);

FpuDsr1WrFp1H      :=  
    VAND3(FpuDetStallDetH, NOT SpuStallExeH, NOT FpuDsr1Vld111H); ! Load the ExeDSR
vDFF(CLKGPU4, FpuDsr1WrFp1H, FpuDsr1WrFp2H);
vDFF(CLKGPU4, FpuDsr1WrFp2H, FpuDsr1WrFp3H);
vDFF(CLKGPU4, FpuDsr1WrFp3H, FpuDsr1WrFp4H);

FpuDsr1VldFp1H      :=  
    vOR2(FpuDsr1WrFp1H, VAND2(FpuDsr1Vld111H, NOT FpuAdvRegH));
vRSdff(CLKGPU4, FpuResetAsynch111H, FpuDsr1VldFp1H, FpuDsr1Vld111H);

FpuDsr1RdFp1H      :=  
    VAND2(FpuAdvRegH, FpuDsr1Vld111H);           ! Read the ExeDSR
vDFF(CLKGPU4, FpuDsr1RdFp1H, FpuDsr1RdFp2H);
vDFF(CLKGPU4, FpuDsr1RdFp2H, FpuDsr1RdFp3H);
vDFF(CLKGPU4, FpuDsr1RdFp3H, FpuDsr1RdFp4H);

FpuExcpUpdFp2H      :=  
    VAND2(fp_SirStallFp2H, NOT fp_SirStallWrbH);
vDFF(CLKGPU4, FpuExcpUpdFp2H, FpuExcpUpdFp3H);
vDFF(CLKGPU4, FpuExcpUpdFp3H, FpuExcpUpdFp4H);
FpuExcpAdvExeH      :=  
    vOR2(NOT DccStallDetH, FpuExcpUpdFp4H);

! !-----  

! !=====  

! !  FP PMU Events  

! !=====

! ports 4,5(f0,f1) instructions which would have been retired if predicate was
! true instead of being false. this event is qualified with tag generated by
! IBRO/1 and pmc8 in isddfts.
FORC k := 0 UPTO 1 DOC
    ASSIGNC p := k+4 ENDC

pmc8f%k%tagregh := isddbgp%p%tagregh[0];
vRESdff(CLKGPU4, FpuFlushRegH, FpuEnableRegH, Pmc8f%k%TagRegH, Pmc8f%k%TagExeH);

FpuSyllQpOff%k%Fp1H      :=  
    VAND3(FpuF%k%SyllVldFp1H, NOT SpuQp%p%ExeH, Pmc8f%k%TagExeH);
vRESdff(CLKGPU4, FpuFlushExeH, FpuEnableExeH,
    FpuSyllQpOff%k%Fp1H, FpuSyllQpOff%k%DetH);

! ports 4,5(f0,f1) instructions which are nops and have true predicates. this
! event is qualified with tag generated by IBRO/1 and pmc8 in isddfts.
FpuNopsVld%k%Fp1H      :=
```

```

        fpuctrls.txt
    vand3(FpuF%k%VldOpFp1H, FpuF%k%NopFp1H, Pmc8f%k%TagExeH);
    vRESdff(CLKFP4, FpuFlushExeH, FpuEnableExeH,
              FpuNopsVld%k%Fp1H, FpuNopsVld%k%DetH);
ENDC

! Count False SIR assertions
! SIR && Vld_Unsafe_Inst && !(Fault_or_Trap)
FpuPmFalseSIRFd4H := 
    VOR2(vAND2(FpuF0IsUnsafeFd4H,
                VOR2(vBNOR(f0_TrapStatFd4H[5:0]),
                      vBNOR(f0_SimdTrapStatFd4H[5:0]))),
    vAND2(FpuF1IsUnsafeFd4H,
                VOR2(vBNOR(f1_TrapStatFd4H[5:0]),
                      vBNOR(f1_SimdTrapStatFd4H[5:0]))));
vDFF(CLKFP4, FpuPmFalseSIRFd4H, FpuPmFalseSIRFwbH);

!FpuSIRMcaFd4H := 
    VOR2(vAND3(FpuF0VldOpCmtFp4H, NOT FpuF0IsUnsafeFd4H,
                VOR2(vBOR(f0_TrapStatFd4H[5:0]),
                      vBOR(f0_SimdTrapStatFd4H[5:0]))),
    vAND3(FpuF1VldOpCmtFp4H, NOT FpuF1IsUnsafeFd4H,
                VOR2(vBOR(f1_TrapStatFd4H[5:0]),
                      vBOR(f1_SimdTrapStatFd4H[5:0])));

!FV_FORBIDDEN(vAND2(NOT FpuF0IsUnsafeFd4H,
                    VOR2(vBOR(f0_TrapStatFd4H), vBOR(f0_SimdTrapStatFd4H))),
    ("F0 signals FP Fault/Trap without SIR"));
!FV_FORBIDDEN(vAND2(NOT FpuF1IsUnsafeFd4H,
                    VOR2(vBOR(f1_TrapStatFd4H), vBOR(f1_SimdTrapStatFd4H))),
    ("F1 signals FP Fault/Trap without SIR"));

! Count number of flops retired
vDFF(CLKFP4, FpuFlopCntFp4H, FpuPmFlopCntFwbH);

! Count failed fchkf inst
vDFF(CLKFP4, FpuExcpAdvExeH, FpuSpecOpFltFp4H, FpuPmFailedFchkfDetH);

===== Pipeline advance/flush signals =====

! Official Reset Macro
resInt(CLKFP4, FpuResInL, FpuResOutL, FpuResetAsynch111H);

! Delayed version of XpnFlush
vDFF(CLKFP4, XpnBruFlushWrbH, FpuXBFflushwb1H);
FV_FORBIDDEN(FpuXBFflushwb1H AND XpnCommit4WrbB,
    ("Xpncommit for F0 is not zero 1 clk after xpnflush"));
FV_FORBIDDEN(FpuXBFflushwb1H AND XpnCommit5WrbB,
    ("Xpncommit for F1 is not zero 1 clk after xpnflush"));

! Pipestage enable signals for Main Pipeline
!FpuEnableExpH := 
    VNOR4(RseStallRenH, SpuStallExeH, DccStallDetH, fp_SirStallFp2H);
FpuEnableRenH := 
    VNOR3(SpuStallExeH, DccStallDetH, fp_SirStallFp2H);
FpuEnableRegH := 
    VNOR3(SpuStallExeH, DccStallDetH, fp_SirStallFp2H);
FpuEnableExeH := 
    VNOR2(DccStallDetH, fp_SirStallFp2H);

! Pipestage flush signals for Main Pipeline
FpuFlushRenH := 

```

```

fpucntrls.txt
  vOR3(FpuResetAsynch111H, FpuXBFflushWb1H, RseStallRenH AND FpuEnableRenH);
FpuFlushRegH  :=
  vOR2(FpuResetAsynch111H, FpuXBFflushWb1H);
FpuFlushExeH  :=
  vOR3(FpuResetAsynch111H, FpuXBFflushWb1H, SpuStallExeH AND FpuEnableExeH);
FpuFlushDeth  :=
  vOR4(FpuResetAsynch111H, FpuXBFflushWb1H, DccStallDeth, fp_SirStallFp2H);

! Pipestage enable signals for FP Pipeline
FpuEnableFp1H  :=
  vNOT(DccStallDeth);

! Pipestage flush signals for FP Pipeline
FpuFlushFp1H  :=
  vOR3(FpuResetAsynch111H, FpuXBFflushWb1H, SpuStallExeH AND FpuEnableFp1H);
FpuFlushFp2H  :=
  vOR3(FpuResetAsynch111H, FpuXBFflushWb1H, DccStallDeth);

! Pipestage advance signals
FpuAdvExpH := vNOR4(RseStallRenH, SpuStallExeH, DccStallDeth, fp_SirStallFp2H);
FpuAdvRenH := vNOR3(SpuStallExeH, DccStallDeth, fp_SirStallFp2H);
FpuAdvRegH := vNOR3(SpuStallExeH, DccStallDeth, fp_SirStallFp2H);
FpuAdvFp1H := vNOT(DccStallDeth);

FpuEnableOnSpuRegH :=
  (SpuStallExeH OR DccStallDeth OR Fp_SirStallFp2H) NAND
  (NOT SpuStallExeH);

END "fpucntrls MAIN";
END "fpucntrls";

```

---

#### Modification History

---

Name:  
 Date:  
 ECO: <if applicable>  
 Bug Number(s): <if applicable>  
 Description:

Name:  
 Date:  
 ECO: <if applicable>  
 Bug Number(s): <if applicable>  
 Description:

---

Modification Log:  
 \$Log: fpucntrls.hdl,v \$  
 Revision 1.22 1998/12/04 00:11:53 gwelte  
 Author: gwelte@eslint4.fc.hp.com (Gary Welte)  
 gun0\_419 update

Revision 1.21.2.1 1998/11/19 23:34:18 rxb  
 Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
 PCO\_01706: BRANCH FROM 1.21.1.1: Implement FPU pmu events, cleanup fp ctl

Revision 1.21 1998/10/30 22:09:08 mjl  
 Author: mjl@hpesmjl.fc.hp.com (Michael J. Lee)  
 gun0\_414 update

fpucntrls.txt

Revision 1.20.2.1 1998/10/28 17:33:42 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01599: BRANCH FROM 1.20.1.1: FPU bug fixes

Revision 1.20 1998/10/21 17:53:35 gwelte  
Author: gwelte@eslint4.fc.hp.com (Gary Welte)  
gun0\_412 update

Revision 1.19.2.2 1998/10/20 15:15:06 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01553: Fix FPU bug 3305

Revision 1.19 1998/10/07 05:35:10 mjl  
Author: mjl@mt1gv21.fc.hp.com (Michael J. Lee)  
gun0\_408 update

Revision 1.18.2.1 1998/10/06 14:09:19 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01489: BRANCH FROM 1.18.1.1: Fix bug 3351

Revision 1.18 1998/09/23 14:49:35 gwelte  
Author: gwelte@eslint4 (Gary Welte)  
gun0\_404 update

Revision 1.17.2.3 1998/09/18 20:41:20 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01407: Implement SoftSIMD and remove simdmacs

Revision 1.17 1998/08/28 20:37:19 h1cad  
Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_400 update

Revision 1.16.1.1 1998/08/27 15:05:58 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01331: Add 2-stage DSR in FPU

Revision 1.16 1998/08/12 21:43:59 h1cad  
Author: h1cad@mt1gv03.fc.hp.com (Generic CAD user)  
gun0\_338 update

Revision 1.15.2.1 1998/08/11 15:30:10 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01229: BRANCH FROM 1.15.1.1: Fix bug 2390

Revision 1.15 1998/08/07 03:32:43 h1cad  
Author: h1cad@mt1gv01.fc.hp.com (Generic CAD user)  
gun0\_337 update

Revision 1.13.2.1 1998/08/04 14:42:39 pjk  
Author: pjk@hpespjk.fc.hp.com (Patrick Knebel)  
PCO\_01182: BRANCH FROM 1.13.1.1: re-order bifrost fpu events from fpu->xpn->bif

Revision 1.13.1.1 1998/07/30 17:15:40 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01164: Switch FPU over to DccStallDeth; Bif FP cflags cleanup; fix bug 1932

Revision 1.13 1998/07/29 04:01:39 h1cad  
Author: h1cad@mt1gv01.fc.hp.com (Generic CAD user)  
gun0\_335 update

Revision 1.12.1.1 1998/07/28 14:30:43 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)

fpuctrls.txt

PCO\_01137: Clean up IEU decode fubs; Fix bug 2379

Revision 1.12 1998/07/22 16:53:59 h1cad

Author: h1cad@mt1gv01.fc.hp.com (Generic CAD user)  
gun0\_333 update

Revision 1.11.1.2 1998/07/17 17:37:36 rxb

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_01092: bug fixes; acr fixes; Bif FP enhancements

Revision 1.11 1998/07/01 23:10:52 h1cad

Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_330 update

Revision 1.10.1.2 1998/06/29 21:29:37 ravi

Author: ravi@hpesravi.fc.hp.com (Ravi Koshy)  
PCO\_00995: Signal cleanup and aligning the immed field

Revision 1.10 1998/06/11 19:49:09 h1cad

Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_327 update

Revision 1.9.2.1 1998/06/09 21:58:14 rxb

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00923: BRANCH FROM 1.9.1.1: Scuds is history !!

Revision 1.9 1998/05/22 18:45:01 h1cad

Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_322 update

Revision 1.8.2.1 1998/05/20 16:31:11 rxb

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00833: BRANCH FROM 1.8.1.1: Partial fix for bug 1539/1557

Revision 1.8 1998/04/27 21:28:16 gwelte

Author: gwelte@eslint4 (Gary Welte)  
gun0\_316 update

Revision 1.7.2.1 1998/04/22 03:06:58 rxb

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00689: Bifrost support for FSR updates, FP exceptions

Revision 1.7 1998/03/30 21:54:16 h1cad

Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_310 update

Revision 1.6.3.1 1998/03/26 22:13:08 rxb

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00578: Bifrost support in FPU

Revision 1.6.2.1 1998/03/25 17:10:54 ravi

Author: ravi@hpesravi.fc.hp.com (Ravi Koshy)  
PCO\_00574: cleaning up the fpu wrapper

Revision 1.6.1.1 1998/03/23 20:48:56 rxb

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00566: Fix bugs 856 932 954 1004

Revision 1.6 1998/03/18 00:49:39 h1cad

Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_306 update

Revision 1.5.2.1 1998/03/16 22:17:41 rxb

fpuctrls.txt

Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00545: Clean up FP Ctrl-Stack exception interface

Revision 1.5 1998/02/20 22:46:59 h1cad  
Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_300 update

Revision 1.4.3.2 1998/02/19 18:39:29 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00459: IEU,FPU bug fixes; Globals changes for IEU

Revision 1.4 1998/01/27 00:52:55 gwelte  
Author: gwelte@intgv03.fc.hp.com (Gary Welte)  
gun0\_227 update

Revision 1.3.1.1 1998/01/22 22:10:18 pjr  
Author: pjr@hpespjr.fc.hp.com (Preston Renstrom)  
PCO\_00372: New register file and bypass valids

Revision 1.3 1998/01/14 02:17:46 h1cad  
Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
gun0\_223 update

Revision 1.2.2.1 1998/01/09 22:21:15 rxb  
Author: rxb@hpesrxb.fc.hp.com (Rohit Bhatia)  
PCO\_00321: Update FPU-XPN interface

Revision 1.2 1997/10/28 20:55:04 h1cad  
Author: h1cad@hpesgd01.fc.hp.com (Generic CAD user)  
! -r? /p7/nohdr

Revision 1.1.1.5 1997/10/23 04:07:08 ravi  
Author: ravi@hpesravi.fc.hp.com (Ravi Koshy)  
PCO\_00180: fpu ctrl signals moved up 1 cycle; new opcodes/encodings

=====